## **DAILY ASSESSMENT**

| Date:                 | 3-6-2020                                                                                                                                             | Name:                     | Kavyashree m      |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------|
| Course:               | Digital design using HDL                                                                                                                             | USN:                      | 4al15ec036        |
| Topic:                | EDA Playground Tutorial Demo Video, How to Download<br>And Install Xilinx Vivado Design Suite, Vivado Design<br>Suite for implementation of HDL code | Semester<br>&<br>Section: | 8 <sup>th</sup> A |
| Github<br>Repository: | kavya                                                                                                                                                |                           |                   |

# FORENOON SESSION DETAILS Image of session Travelling Expenses... Search Search

Fig 1: EDA Playground Tutorial Demo Video



Fig 2: How to Download And Install Xilinx Vivado Design Suite



Fig 3: Vivado Design Suite for implementation of HDL code

## **Download And Install Xilinx Vivado Design Suite**

Vivado is the software that Xilinx has available for all of its current FPGAs, so we'll go through how to download the free WebPACK version of Vivado.

First, we have to download Vivado. Once you get to the download page, choose the appropriate installer for your system.



If you're familiar with Digilent, you'll know that we have a wide variety of Field Programmable Gate Arrays that can do many strange, complex, and wonderful things if you program them to do so. The big catch with this is that you have to download the software in order to program them. Simple right? Maybe not for everybody- otherwise we wouldn't see questions on how to get FPGAs up and running for the first time. Vivado is the software that Xilinx has available for all of its current FPGAs, so we'll go through how to download the free WebPACK version of Vivado.



Once you get to the download page, choose the appropriate installer for your system; I'm on a Windows 10 machine and don't feel the need to get a universal, all OS installer, so I'll choose the Windows Self Extracting Web Installer.



#### Which Vivado WebPACK installer do I choose?

Xilinx likes to know what demographic of people use their software so you'll need to either sign in to your pre-existing account or create one with Xilinx.



Sign into your Xilinx account or create a Xilinx account to download the web installer. Once you sign in, go ahead and let your chosen installer download and then let it run.



#### Downloading the Vivado web installer

You'll first be brought to a friendly opening screen where it asks you to confirm that you have a compatible OS so you don't download a large file only to have it not work.

You can also choose some installation preferences such as how many cores your computer utilizes to download Vivado, but I went with all of the default preferences.



Make sure you have a compatible OS before downloading Vivado.Xilinx will ask you to sign in again and choose how you want to download/install.choose the "Download and Install Now" to make I only download what I need to help conserve space on my laptop.

#### Vivado Design Suite for implementation of HDL code

- 1. In a separate web browser window, log in to EDA Playground.
- 2. Log in. Click the Log in button (top right) Then either
- click on Google or Facebook or
- register by clicking on 'Register for a full account' (which enables all the simulators on EDA Playground)
- 1. Select 'Aldec Riviera Pro' from the Tools & Simulators menu. This selects the Aldec Riviera Pro simulator, which can be used however you logged in. Using certain other simulators will require you to have registered for a full account.

- 2. In either the *Design* or *Testbench* window pane, type in the following code:
- 3. module test;
- 4. initial
- 5. \$display("Hello World!");
- 6. endmodule
- 7. Click Run (top left)

Yes, running a simulation is as simple as that!

- 8. In the bottom pane, you should see real-time results as your code is being compiled and then run. A run typically takes 1-5 seconds, depending on network traffic and simulator. Near the bottom of result output, you should see:
- 9. Hello World!
- 10. Now, let's save our good work. Click the Share tab near in the bottom pane and then type in a name and description. Then click Save.
- 11. The browser page will reload and the browser address bar will change. This is a persistent link to your saved code. You can send the link by email, post it on a web page, post it on Stack Overflow forums, etc.
- 12. Now, let's try modifying existing code. Load the following example: RAM
- 13.On the left editor pane, before the end of initial block, add the following:

```
14. write_enable = 1;
```

 $15.data_write = 8'h2C;$ 

16.toggle\_clk\_write;

17.toggle\_clk\_read;

18.\$display("data[%0h]: %0h",

- 19. address\_read, data\_read);
- 20. Run the sim. In the results you should see this new message:
- 21.data[1b]: 2c

22. Optional. Click *Copy* to save a personal version of the modified *RAM* code, including the simulation results.

Loading Waves from EDA Playground

You can run a simulation on EDA Playground and load the resulting waves in EPWave. Loading Waves for SystemVerilog and Verilog Simulations

- Go to your code on EDA Playground. For example: RAM Design and Test
- Make sure your code contains appropriate function calls to create a \*.vcd file. For example:
- initial begin
- \$dumpfile("dump.vcd");
- \$dumpvars(1);
- end
- Select a simulator and check the Open EPWave after run checkbox. Click Run. After the run completes, the resulting waves will load in a new EPWave window.
- Loading Waves for VHDL Simulations
- Check the Open EPWave after run checkbox.
- Specify the Top entity to simulate.
- Click Run. After the run completes, the resulting waves will load in a new EPWave window. (Pop-ups must be enabled.)
  - The waves for all signals in the specified Top entity and any of its components will be dumped.
  - o In EPWave window, click Get Signals to select the signals to view.

#### AFTERNOON SESSION DETAILS

| Date:                 | 3-6-2020                                      | Name:               | Kavyashree m      |
|-----------------------|-----------------------------------------------|---------------------|-------------------|
| Course:               | Python programming                            | USN:                | 4al15ec036        |
| Topic:                | Scrape Real Estate Property Data from the Web | Semester & Section: | 8 <sup>th</sup> A |
| Github<br>Repository: | Kavya                                         |                     |                   |

# 

Image of session

Fig 1: Scrape Real Estate Property Data from the Web

Bookmarks

#### Web Scraping in real estate to the rescue

Web scraping is the process of sorting through overwhelming amounts of data, refine the user's searches and provide a list of relevant information. In a realtor's case, it is the go-to tool for organized property listings. Scraping the web provides parameters which the realtor can further study to determine sales and prospective buyers. Parameters extracted by web scraping are:

Size

- Property type
- Location
- Sale price
- Size
- Amenities
- Monthly rental price
- Parking spaces
- Agent contact

This information is displayed in form of a spreadsheet, allowing the realtor to make comparisons of relevant parameters.

#### **Property value tracking**

Let's assume you decide to sell your property. Scraping the web for the value of similar properties can aid you in setting a good value on your own. This allows users searching for such properties to get fair deals, and on the other, you getting a profitable one.

#### Making the right investment

Obtaining real estate data is hard, as result of which most investors make financial investments blindly. ith web scraping, an investor can make decisions based on qualitative and relevant empirical data, rather than outdated or incomplete information. Aggregating property data from real estate listing websites is essential for investment analysis.

#### **Rental Yield**

Rental yield is the most important factor to be considered before investing in property. By scraping data from real estate websites, you can determine which properties have the best rental yield for any suburb. Moreover, scraping answers which property types (house, apartment, 1 bedroom, 2 bedrooms) are more preferred in a particular area and yield the best return on investment.

#### **Track vacancy rates**

A vacant investment property is risky. To minimize this risk, it is imperative to analyze property data and suburbs which have higher rental listings. The above parameters are the most relevant decoded by web scraping through numerous websites online. Having the above details at your fingertips improves a realtor's efficacy at decision making, better communication and faster and profitable sales. The role of web scraping in retail is just getting started, its potential is however limitless.

#### **Loading the Webpage in Python**

They are highly specialized programming language embedded in Python. We can use it through re module of Python. It is also called RE or regexes or regex patterns. With the help of regular expressions, we can specify some rules for the possible set of strings we want to match from the data.

If you want to learn more about regular expression in general, go to the link https://www.tutorialspoint.com/automata\_theory/regular\_expressions.htm and if you want to know more about re module or regular expression in Python, you can follow he link

https://www.tutorialspoint.com/python/python\_reg\_expressions.htm.

```
Example
In the following example, we are going to scrape data about India
from http://example.webscraping.com after matching the contents of  with the
help of regular expression.
import re
import urllib.request
response =
urllib.request.urlopen('http://example.webscraping.com/places/default/view/India-
102')
html = response.read()
text = html.decode()
re.findall('(.*?)',text)
Output
The corresponding output will be as shown here –
[
 '<img src="/places/static/images/flags/in.png"/>',
 '3,287,590 square kilometres',
 '1,173,108,018',
 'IN',
 'India',
 'New Delhi',
 '<a href="/places/default/continent/AS">AS</a>',
 '.in',
 'INR',
 'Rupee',
 '91',
```

#### Extracting "div" Tags

Extracting a div tag and its contents by id parses a block of HTML code and returns a string containing the value held within the div tag.

Call urllib.request.urlopen(url) to open a request of url. Use http.client.HTTPResponse.read() to return the HTML content of the request. Use bs4.BeautifulSoup(content, format) with format as "html" to parse this content. Call BeautifulSoup.find(tag\_type, id\_value) with tag\_type as "div" and id\_value as a dictionary with the syntax {"id": value} to extract a div tag by its id value. Use str() to convert the resultant content to a string.

```
url = "http://kite.com"
url_contents=urllib.request.urlopen(url).read()
soup = bs4.BeautifulSoup(url_contents, "html")
```

```
div = soup.find("div", {"id": "home-template"})
content = str(div)
print(content[:50])
print start of string
```

#### **OUTPUT**

<div id="home-template"><div class="homepage-banne"</pre>

#### **Extracting Elements without Unique Identifiers**

We can use the class attribute of certain elements to filter down results. For example, looking at the list of blockquote elements returned by the previous query, and by looking at this page's source, we can see that the blockquote elements on this page have different classes.

To refine the above query to get all the blockquote elements of the challenge class, we can type

document. query Selector All ('block quote.challenge')

which returns

<-Array[<blockquote.challenge>,<blockquote.challenge>,

<blockquote.challenge>, <blockquote.challenge> ]

#### Writing the Extracted Data in CSV Files

CSV (Comma Separated Values) is a simple file format used to store tabular data, such as a spreadsheet or database. CSV file stores tabular data (numbers and text) in plain text. Each line of the file is a data record. Each record consists of one or more fields, separated by commas. The use of the comma as a field separator is the source of the name for this file format.

Python provides an in-built module called csv to work with CSV files. There are various classes provided by this module for writing to CSV:

- Using csv.writer class
- Using csv.DictWriter class

Using csv.writer class

csv.writer class is used to insert data to the CSV file. This class returns a writer object which is responsible for converting the user's data into a delimited string. A csvfile object should be opened with newline=" otherwise newline characters inside the quoted fields will not be interpreted correctly.

csv.writer class provides two methods for writing to CSV. They are writerow() and writerows().

• writerow(): This method writes a single row at a time. Field row can be written using this method.

#### **Syntax:**

writerow(fields)

• writerows(): This method is used to write multiple rows at a time. This can be used to write rows list.

#### **Syntax:**

Writing CSV files in Python writerows(rows)

## Task 3

# Implement 4 to 1 MUX using two 2 to 1 MUX using structural modelling style and test the module in online/offline compiler.

```
module and_gate(output a, input b, c, d);
assign a = b \& c \& d;
endmodule
module not_gate(output f, input e);
assign e = \sim f;
endmodule
module or_gate(output l, input m, n, o, p);
assign 1 = m \mid n \mid o \mid p;
endmodule
module m41(out, a, b, c, d, s0, s1);
output out;
input a, b, c, d, s0, s1;
wire s0bar, s1bar, T1, T2, T3;
not_gate u1(s1bar, s1);
not_gate u2(s0bar, s0);
and_gate u3(T1, a, s0bar, s1bar);
and_gate u4(T2, b, s0, s1bar);
and_gate u5(T3, c, s0bar, s1);
and_gate u6(T4, d, s0, s1);
or_gate u7(out, T1, T2, T3, T4);
endmodule
```

